/**
 * 
 * 免单统计
 * 
 * 题目描述

华为商城举办了一个促销活动，如果某顾客是某一秒内最早时刻下单的顾客（可能是多个人），则可以获取免单。

请你编程计算有多少顾客可以获取免单。

输入描述
输入为 n 行数据，每一行表示一位顾客的下单时间以（年-月-日 时-分-秒.毫秒）形式给出。

yyyy-MM-dd HH:mm:ss.fff
0 < n < 50000
2000 < yyyy < 2020
0 < MM ≤ 12
0 < dd ≤ 28
0 ≤ HH ≤ 23
0 ≤ mm ≤ 59
0 ≤ ss ≤ 59
0 ≤ fff ≤ 999
所有输入保证合法。

输出描述
输出一个整数，表示有多少顾客可以获取免单。

用例
输入	3
2019-01-01 00:00:00.001
2019-01-01 00:00:00.002
2019-01-01 00:00:00.003
输出	1
说明	样例 1 中，三个订单都是同一秒内下单，只有第一个订单最早下单，可以免单。
输入	3
2019-01-01 08:59:00.123
2019-01-01 08:59:00.123
2018-12-28 10:08:00.999
输出	3
说明	样例 2 中，前两个订单是同一秒内同一时刻（也是最早）下单，都可免单，第三个订单是当前秒内唯一一个订单（也是最早），也可免单。
输入	5
2019-01-01 00:00:00.004
2019-01-01 00:00:00.004
2019-01-01 00:00:01.006
2019-01-01 00:00:01.006
2019-01-01 00:00:01.005
输出	3
说明	样例 3 中，前两个订单是同一秒内同一时刻（也是最早）下单，第三第四个订单不是当前秒内最早下单，不可免单，第五个订单可以免单。

 */

import java.util.Arrays;
import java.util.Scanner;

/**
 * 
 * 题目解析
考察排序以及字符串操作。
 */
public class 免单统计 {
    
    public static void main(String[] args) {
    

         Scanner sc = new Scanner(System.in);
 
        int n = Integer.parseInt(sc.nextLine());
 
        String[] times = new String[n];
        for (int i = 0; i < n; i++) {
            times[i] = sc.nextLine();
        }
 
        // 时间升序
        Arrays.sort(times);
 
        // 免单顾客数量
        int ans = 1;
 
        // 当前秒的最早时刻
        String last = times[0];
        String lastSecond = last.substring(0, 19);
 
        for (int i = 1; i < n; i++) {
            String cur = times[i];
            String curSecond = cur.substring(0, 19);
 
            // 同一时刻 或者 不是同一秒
            if (cur.equals(last) || !curSecond.equals(lastSecond)) {
                ans++;
 
                last = cur;
                lastSecond = curSecond;
            }
        }
 
        System.out.println(ans);
    }
}
